Как мы притон й 
В массу блюдиз^ 

‚одного ин редиен е нта: 
Сгарв ог. 


| | 
ей ра КТ... 

Л руководитель команд разработки, 
| Группа НЛМК 


РНР Ривза: 


` 2922 


О чем пойдет речь в докладе 


ПОТРЕБИТЕЛИ 


ПОСТАВЩИК Цель: 


ПОТРЕБИТЕЛЬ 
Рассказать историю построения эффективного 


интеграционного взаимодействия с информационными 
системами на базе СгарК О! 


ПОСТАВЩИКИ 


О чем пойдет речь в докладе 


1. Немного о нас 


2. Потребитель \/$ поставщик 
Потребитель 

Поставщик 

«Правила игры» поставщика 
З{ер Бу %ер \5 Опе “ер 
Выводы 


о 


3. СгарНОГ: внедрение и советы 
1. Базовая структура 
2. Производительность: составной запрос (Опе $%ер) 
3. Безопасность: Разграничение прав доступа (\М/НКе 1151) 
4. Гибкость: Реализация сложных фильтров с логикой ОВ/АМО 


4. Выводы 


Раздел 1. О нас 
(нлмк) 1. Группа НЛМК 


НЛМК Липецк (В >50 000 сотрудников 


т в России и за рубежом 
НЛМК Калуга ее 
Сталь 
Прокат 
НЛМК США 
Сталь | вИЗ-Сталь (@) >18 млн тонн 
Прокат мощности по производству стали 
НЛМК Дания Дания Прокат щ р дству 
Прокат Ба 9 


Ш Италия 
НЛМК Европа (СП) Франция 


СТОЙЛЕНСКИЙ ГОК © 1 место в России 
к НЛМК Индия = 
Прокат зн Концентрат по выпуску стали 
Сервисный центр Окатыши Алтай-Кокс 


Кокс 


20 площадок в 7 странах 


производственные активы 


1. Единый корпоративный портал Группы НЛМК 


>80 СЕРВИСОВ 


из различных функциональных направлений со своей бизнес-логикой, 
механизмами интеграций, дорожной картой развития 


СЕРВИСЫ нлмктв 


Комонкй — 


Бе 
_ @® ОФЖНАТРУДА 


= >4 500 ДЕПАРТАМЕНТОВ 


М о29 673 3 иене объединяет портал по орг. структуре 


>50 000 СОТРУДНИКОВ, 


объединенных в одной информационной системе 


>100 ИНТЕРФЕЙСОВ 


взаимодействия с другими системами 


>15 СИСТЕМ, 


с которыми интегрирован портал 


Раздел 2. Потребитель \5 поставщик 
(нлмк) Раздел 2. Потребитель \$ поставщик 


1. Потребитель 
2. Поставщик 
3. «Правила игры» поставщика 


4. З4ер Бу “ер \/$ Опе “ер 


Раздел 2. Потребитель \5 поставщик 
(нлмк) 2.1. Потребитель 


Раздел 2. Потребитель \5 поставщик 
(нлмк) 2.1. Потребитель 
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2.1. Потребитель 
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2.1. Потребитель 


Раздел 2. Потребитель \5 поставщик 
(нлмк) 2.1. Потребитель 


ПОТРЕБИТЕЛЬ 


а. ХМ. 
75ОМ, бЕТ, РОТ 


ПОСТАВЩИКИ 


Раздел 2. Потребитель \5 поставщик 
(нлмк) 2.1. Потребитель 


ПОТРЕБИТЕЛЬ 


ПОРТЕБИТЕЛЬ ЗНАЕТ: 


У какая информация ему необходима и 


` для чего 
ОрРата, ХМ. 
Т$ОМ, СЕТ, РОТ 


У поставщика с которым он будет 
работать 


У язык/способ общения с поставщиком 


ых РНР Козза 


2022 


Раздел 2. Потребитель \/5 поставщик 
(нлмк) 2.1. Потребитель 


ПОСТАВЩИК 
ПОТРЕБИТЕЛЬ 


ПОСТАВЩИКИ 


Раздел 2. Потребитель \5 поставщик 
(нлмк) 2.2. Поставщик 
ПОТРЕБИТЕЛИ 


Раздел 2. Потребитель \5 поставщик 
(нлмк) 2.2. Поставщик 


ПОТРЕБИТЕЛИ 


ПОСТАВЩИК НЕ ЗНАЕТ: 


У количество возможных 
«потребителей»; 


У платформу и технологический стек 
«потребителя» 


У какая информация, ее состав (поля) и 
для чего она нужна «потребителю». 


Раздел 2. Потребитель \5 поставщик 
(нлмк) 2.2. Поставщик 


ПОТРЕБИТЕЛИ 


ПОСТАВЩИК НЕ ЗНАЕТ: 


У количество возможных 
«потребителей»; 


У платформу и технологический стек 
«потребителя» 


У какая информация, ее состав (поля) и 
для чего она нужна «потребителю». 


||| Необходимы собственные «правила игры» !!! 


Раздел 2. Потребитель \5 поставщик 
(нлмк) 2.3. «Правила игры» поставщика 


Поставщик должен: 


У быть единообразным. Работать одинаково для всех 
«потребителей» без исключения 


ПОТРЕБИТЕЛИ ПОТРЕБИТЕЛИ 


ПОСТАВЩИК 


Раздел 2. Потребитель \5 поставщик 
(нлмк) 2.3. «Правила игры» поставщика 


Поставщик должен: 


У быть единообразным. Работать одинаково для всех 
«потребителей» без исключения 


У работать по принципу Опе $ер, т.е. за один шаг/запрос 
отдавать требуемую информацию (опе-$ер) 


Раздел 2. Потребитель \/5 поставщик 
2.4. Зер Бу “ер \/5 Опе %ер 


ВЕРХНЕУРОВНЕВАЯ ЕВР-ДИАГРАММА НОВОСТИ 


$ОУВСЕТЬ  э> Новость (пем$) | — ЕР 
ЕВ 8 - ть ЕТВ$Т_МАМЕ 
п. м ^^. ГАЗТ_МАМЕ 
ТЕХТ 


СВЕАТЕ_РАТЕ 


ТО РОВЕТ$Н_БАТЕ то 
МАМЕ РВЕМТЕМ/ _ТЕХТ ти 
СОБЕ А АЦЧТНОВ 


ОАТЕ_СВЕАТЕ 


5$ОЧВСЕ_ТЬ 


Раздел 2. Потребитель \5 поставщик 
2.4. Зер Бу “ер \/5 Опе %ер 


ЗТер-Бу- тер 


(@-]:7- 
Пользователь РРР хе 
приложений 
1 


Вывод страницы 


Запрос чзег$ 
р ьЕН Отдача изег$ 


новостей | Й 
Запрос пем$ 
Запрос В 
В ---Отдача соттей1$ ---- 
Запрос мемз 
Запрос ги ОМ 
Отдача гибмс$----- 
.. 9 


= 
тдача страницы _ в 
новостей 


| 
| 
| 
| 
| 
| 
| 
| 
| 
| 


Раздел 2. Потребитель \5 поставщик 
2.4. Зер Бу “ер \/5 Опе %ер 


Опе- тер 


Серве 
Пользователь РР 9 
приложений 
| 


Запрос 
| Вывод страницы 


| 
ь пем/5, 
Новой соттейт$, 
мем/$, 
гибБгс$, 
и5ег$ 
| 
| 
Отдача 
пем5, 
ИИ сотиейт$, 
__ Отдача страницы_ _ Г а. 


гиБтс$, 
и5ег$ 


новостей 


Раздел 2. Потребитель \5 поставщик 


2.4. Мер Бу %“ер \5 Опе чер 


[Аа 


Зтер- Бу-зТер Опе- $Тер 


Серве Серве 
Пользователь Ре. Пользователь а 
приложений приложений 
[ 


| Запрос 


| р 
Вывод страницы ооо ооооооьоо Вывод страницы ю © ре ПС юоофоощеоооое 
новостей | новостей 
соттейт$, 
Запрос пемз . 
| мемз, 
гиБтС$, 
| | изег$ 
Запрос ИИ | | 
| | 
---Отдача соттеи{$ ---- Отдача 
| 
| 
| 
=> 


те 


г р 
и. мем Пе: 


сотилеп{5, 
мемс, 

© а гб С5, © ФФ ооо 
у5ег$ 


Отдача страницы _ 
новостей 
Отдача гиБ"!с$ 


Запрос изег$ 
__ Отдача страницы _ 
<“ новостей 


тах 


Раздел 2. Потребитель \5 поставщик 
(нлмк) 2.4. Зер Бу “ер \/5 Опе %ер 


З4ер Бу “ер Опе $%ер 


Производительность — низкая У высокая 
множество накладных расходов 
(сеть/транспорт, анализ запросов, 
формирование ответов и т.д.) 


Система управления знаниями — сложная У простая 
множества методов под каждый объект и их единый формат запроса/ответа 
кросс-функциональное взаимодействие 


Порог вхождения У относительно невысокий — более высокий порог вхождения 
порог вхождения требуется знать специфику работы умного 
в архитектуру ВЕЗТ и написания «простых» епаротга 


ВИр($)-запросов 


3. бгарНОГ: внедрение и советы 
(нлмк) 3. бгарпО1: внедрение и советы 


ПОСТАВЩИК 
ПОТРЕБИТЕЛЬ 


ПОСТАВЩИКИ 


3. бгарНОГ: внедрение и советы 
(нлмк) 3. бгарпОи!: внедрение и советы 


СгарПО! - язык запросов с открытым исходным 
кодом. 


Три основные характеристики: 


У позволяет клиенту точно указать, какие 
данные ему нужны. 


У облегчает агрегацию данных из 
нескольких источников. 


У использует систему типов для описания 
данных. 


аи ог 


В качестве основы мы используем библиотеку НИ рз://=ИПиЬ.сот/мебопух/вгарпа!-рйр, которая соответствует 


изначально заложенной спецификации. 


3. бгарНОГ: внедрение и советы 
(нлмк) 3. бгарпО!: внедрение и советы 


ПОТРЕБИТЕЛИ 


ПОСТАВЩИК 
ПОТРЕБИТЕЛЬ 


ОБала, ХМЕ. 
150, СЕТ, РОТ 


р 59 


ПОСТАВЩИКИ 


3. бгарНОГ: внедрение и советы 
(нлмк) 3. бгарпО1: внедрение и советы 


1. Базовая структура 


2. Безопасность 
Разграничение прав доступа (М/ПКе 1151) 


3. Производительность 
Составной запрос (Опе $%ер) 


4. Гибкость 
Реализация сложных фильтров с логикой 
ОВ/АМО 


В бгарп! АР! существует 2 корневых типа 

данных*: 

. _ МщаНопТуре — используется для 
изменения информации 

.  ОчегуТуре - используется для получен 
информации 


* Есть третий тип данных «Подписка», но он реализован 
только для «реактивных» библиотек РНР или РНР >8.1 
(актуально для библиотеки 
ВИрз://вНВиЬ.сот/меБопух/эгарНа!-рИНр } 


‚ РНР Кизза 
’ 2022 


В бгарПОГ! АР! существует 2 корневых типа 

данных*: 

. _ МщаНопТуре — используется для 
изменения информации 

‚  ОчегуТуре - используется для получения 
информации 


Реестр «кастомных» типов данных 
для расширения простых типов данныж. 


* Есть третий тип данных «Подписка», но он реализован 
только для «реактивных» библиотек РНР или РНР >8.1 
(актуально для библиотеки 
ВИрз://вИВиЬ.сот/\меБопух/эгарНа!-рйНр } 


‚ РНР Кизза 
’ 2022 


В бгарПОГ! АР! существует 2 корневых типа 

данных*: 

. _ МущаНопТуре — используется для 
изменения информации 

.  ОчегуТуре - используется для получения 
информации 


Реестр «кастомных» типов данных 
для расширения простых типов данныж. 


\ 
\ 
1 
Описание «кастомных» типов ` 
зарегистрированных в Туре$.рпр _ в 


* Есть третий тип данных «Подписка», но он реализован 
только для «реактивных» библиотек РНР или РНР >8.1 
(актуально для библиотеки 
ВИрз://вИВиЬ.сот/\меБопух/эгарНа!-рНр } 


‚ РНР Кизза 
’ 2022 


В бгарПОГ! АР! существует 2 корневых типа 

данных*: 

. _ МущаНопТуре — используется для 
изменения информации 

.  ОчегуТуре - используется для получения 
информации 


Сущности для реализации 
взаимодействия 
контроллера и модели 
данных 


Реестр «кастомных» типов данных 
для расширения простых типов данных. 


\ 
\ 
1 
Описание «кастомных» типов ` 
зарегистрированных в Туре$.рпр _ в 


* Есть третий тип данных «Подписка», но он реализован 
только для «реактивных» библиотек РНР или РНР >8.1 
(актуально для библиотеки 
ВИрз://вИВиЬ.сот/\меБопух/эгарпа!-рНр } 


‚ РНР Кизза 
’ 2022 


3.1. Базовая структура 


3. огарНОГ: внедрение и советы 


а а ое а а а 
‚ геди1ге_опсе геа[рафп('. ./мепдог/аифо1оаа.рйр'); | Е - — (— Определяем единую точку входа 
\ 


гу { 
$гамТпри* = }1[е деЕЁ сопепЕ$('рИр://1при*'); 
$1приЕ = 75оп_аесоае ($гамТпри*, %гче); 
$ачегу = $1при{ [ 'ачегу' ]; 


$5спета = пем $света( [ 
'ачегу' => Турез: :дчегу(), 
‘тисаЕ1оп' => Турез: : тибаЕТоп() 


1); 


$гези1{ = бгарпНОЕ : :ехесифебиегу($5спета, Фачегу); 
фагЕхсер1оп = $гези1*->фоАггау()[ 'еггог$'] ?: []; 


} сафси (ТИгомаб1е $е) { 

$гези1{ = ['еггог' => ['теззаре' => $е->ве{Мез5ате()]]; 
} Е1па11у { 

Гор: : рип ($дчегу, $агЕхсере1оп); 
} 
Реадег ( "'Сопфеп*-Туре: арр11са*1оп/]50п; сПпаг5ет=уТЕ-8'); 
еспо 7]5оп_епсоае ($гези1{); 


/вгарпа/Итаех.рНр: 


‘- 1. Подключаем СбгарпОЕ 


3. огарНОГ: внедрение и советы 
(нлмк) 3.1. Базовая структура 


геди1ге_опсе геа[раЕй('.. /мепаог/ачео1оаа.рИр'); 


Определяем единую точку входа 

/сгарра/таех.рИр: 

УЕ Е ЕАО ЗВЕНЬЯ ь 
$фгамТпри* = }1[е деЕЁ сопфепЕ$('рИир://1при*'); | 
$1приЕ = 75оп_аесоае($гамТпри*, гие); 


№ фачегу = $1при* [ 'диегу' ]; 


^ -2. Получаем исходные данные 


1. Подключаем СбгарКп ОЕ 


$5спета = пем $сНета( [ 
'ачегу' => Турез: :дчиегу(), 
‘тисаЕ1оп' => Турез: : тибаЕТоп() 


1); 


$гези1 = бгарпНОЕ : :ехесифебиегу ($5спета, Фачегу); 
фагЕхсер1оп = $гези1*->фоАггау () [ 'еггог$'] ?: []; 


} сафсй (ТИгомаб1е $е) { 

$гези1* = ['еггог" => ['теззаре' => $е->ве{Мез5аРе()]]; 
} Е1па11у { 

Гор: : ри5И ($ацегу, ФагЕхсер1оп); 


} 
Реадег ( "'Сопфеп*-Туре: арр11са*1оп/]50п; сПпаг5еф=уТЕ-8'); 


еспо 7]5оп_епсоае ($гези1{); 


3. бгарНОГ: внедрение и советы 
(нлмк) 3.1. Базовая структура 


геди1ге_опсе геа[раЕй('.. /мепаог/ацчео1оаа.рИр'); 


Определяем единую точку входа 
/вгарпа/Итаех.рНр: 


{гу { 
фгамТпри® = }1Ё[е деЁ сопфепЕ$5 ("рИир://1при*'); 1. Подключаем бгарК ОЕ 
$1приЕ = 75оп_аесоае($гамТпри*, гие); 
$ачегу = $1при{ [ 'ачегу' ]; 

а 1 р 2. Получаем исходные данные 
'ачегу' => Турез: :дчегу(), | 
'тифае1оп" => Турез: : мифа 1оп() —3. Создаем схему 


1); 


$гези1 = бгарпНОЕ : :ехесифебиегу($5спета, Фачегу); 
фагЕхсер1оп = $гези1*->фоАггау()[ 'еггог$'] ?: []; 


} сафси (ТИгомаб1е $е) { 

$гези1{ = ['еггог" => ['теззаре' => $е->ве{Мез5ате()]]; 
} Е1па11у { 

Гор: : ри ($ацегу, ФагЕхсер1оп); 


} 
Реадег ( "Сопфеп*-Туре: арр11са*1оп/]50п; сПпаг5ет=уТЕ-8'); 


есйо 7]5оп_епсоае ($гези1{); 


3. бгарНОГ: внедрение и советы 
(нлмк) 3.1. Базовая структура 


геди1ге_опсе геа[раЕй('.. /мепаог/ачео1оаа.рИр'); 


Определяем единую точку входа 
/сгарра/таех.рИр: 
{гу { 
$гамТпри* = }1Ёе деЕЁ сопепЕ$('рИр://1при*'); 
$1приЕ = 75оп_аесоае ($гамТпри*, %гче); 
$ачегу = $1при{ [ 'ачегу' ]; 


1. Подключаем Сбгарп ОЕ 


2. Получаем исходные данные 


$эспета = пем $сПета( [ 
‘ачегу' => Турез: :диегу(), 
'тифае1оп" => Турез: : мифа 1оп() 3. Создаем схему 


1); 


|  Фгези1 = бгарпОЕ : :ехесифебиегу($5спета, $ачегу); „-4. Обрабатываем запрос 
| ФагЕхсере1оп = $гези1*->фоАггау() [ 'еггог$'] ?: []; ШЯ- 
} сафси (ТИгомаб1е $е) { 

$гези1* = ['еггог" => ['теззаре' => $е->ве{Мез5аРе()]]; 
} Е1па11у { 

гов: :ризП ($Фачегу, ФагЕхсер1оп); 
} 
Реадег ( "Сопфеп*-Туре: арр11са*1оп/350п; сПпаг5ет=уТЕ-8'); 
есйо 7]5оп_епсоае ($гези1{); 


3. сгарНОГ: внедрение и советы 
(нлмк) 3.1. Базовая структура 


геди1ге_опсе геа[раЕй('.. /мепаог/ацчео1оаа.рИр'); 


Определяем единую точку входа 

/сгарра/таех.рИр: 

{гу { 
$фгамТпри* = }1[е деЕЁ сопепЕ$('рИр://1при*'); 
$1приЕ = 75о0п_аесоае ($гамТпри*, %гче); 
$ачегу = $1при* [ 'ачегу' ]; 


1. Подключаем Сбгарп ОЕ 


2. Получаем исходные данные 


$эспета = пем $сПета( [ 
'ачегу' => Турез: :дчиегу(), 
'тифае1оп" => Турез: : мифа 1оп() 3. Создаем схему 
1); 
$гези1{ = бгарНОГ : :ехесифебиегу ($зспета, $диегу); 4. Обрабатываем запрос 
фагЕхсер1оп = $гези1*->фоАггау()[ 'еггог$'] ?: []; 


й сафси (ТИгомабБ1е $е) { ыЕ 
$гези1{ = ['еггог' => ['теззаве" => фе->ве*Меззаве( ) 1]; МЕЖ «” : 
а С ТОН» 
гов: :ризП ($Фачегу, ФагЕхсер1оп); 
} 
Реадег ( "Сопфеп*-Туре: арр11са*1оп/350п; сПпаг5ет=уТЕ-8'); 


есйо 7]5оп_епсоае ($гези1{); 


Обрабатываем ошибки 


3. бгарНОГ: внедрение и советы 
(нлмк) 3.1. Базовая структура 


геди1ге_опсе геа[раЕй('.. /мепаог/ачео1оаа.рИр'); 


Определяем единую точку входа 

/сгарра/таех.рИр: 

{гу { 
$гамТпри* = }1[е деЕЁ сопфепЕ$('рИр://1при*'); 
$1приЕ = 75о0п_аесоае ($гамТпри*, %гче); 
$ачегу = $1при{ [ 'ачегу' ]; 


1. Подключаем Сбгарп ОЕ 


2. Получаем исходные данные 


$эспета = пем $сПета( [ 
‘'ачегу' => Турез: :диегу(), 
'тифае1оп" => Турез: : мифа 1оп() 3. Создаем схему 
1); 
$гези1& = бгарпО! : :ехесифебиегу ($5спета, $диегу); 4. Обрабатываем запрос 
фагЕхсер1оп = $гези1*->фоАггау () [ 'еггог$'] ?: []; 


5. Обрабатываем ошибки 


1} +1па11у { 
| тов: :ризИ(Фаиегу, ФагЕхсере1оп); 9 -- 6. Производим логирование 


Реадег ( "'Сопфеп*-Туре: арр11са*1оп/350п; сПпаг5ет=уТЕ-8'); 
есйо 7]5оп_епсоае ($гези1*); 


3. сгарНОГ: внедрение и советы 
(нлмк) 3.1. Базовая структура 


геди1ге_опсе геа[раЕР('.. /мепаог/ачео1оаа.рИр'); Определяем единую точку входа 
/сгарра/таех.рИр: 
{гу { 
$гамТпри* = }1[е деЕ сопфепЕ$('рИр://1при*'); 
$1приЕ = 75оп_аесоае ($гамТпри*, %гче); 


$ачегу = $1при{ [ 'ачегу' ]; 


1. Подключаем Сбгарп ОЕ 


2. Получаем исходные данные 


$эспета = пем $сПета( [ 
'ачегу' => Турез: :диегу(), 
'тифае1оп" => Турез: : мифа Топ() 3. Создаем схему 
1); 
$гези1& = бгарпО! : :ехесифебиегу ($зспета, $диегу); 4. Обрабатываем запрос 
фагЕхсер1оп = $гези1*->фоАггау () [ 'еггог$'] ?: []; 


} сафсий (ТИгомаб1е $е) { 


$гези14 = ['еггог' => ['теззаве' => фе->веМеззаве() 1]; Е 5. Обрабатываем ошибки 


} Е1па11у { 
Гор: : ризИ ($ачегу, $агЕхсер*1оп); Е 6. Производим логирование 
РИО ИН 
‚ Реадек(' Сопфепф-Туре: арр11са%1оп/)5$оп; сПагзетф=итТЕ-8' 1 Выводим ответ 
‚еспо 75оп_епсоае ($гези1*); 7. «7 


РНР Низза 


2022 


3. бгарНОГ: внедрение и советы 
(нлмк) 3.1. Базовая структура 


Для создания типа, как правило, достаточно: 


е 
А описать запрос 


о © 
Ш: зарегистрировать его 


“= 1% 
А описать возвращаемые поля 


Еа реализовать взаимодействие с хранилищем 


3. бгарНОГ: внедрение и советы 
(нлмк) 3.1. Базовая структура 


й ( Описываем запрос пем$ 
Г 


Конструктор класса "ОцегуТуре" содержит в себе все подтипы "ачцегу" запросов и он 
{ должен быть наследован от "ОБес Туре", что позволяет создавать свои составные 
типы данных. 


фсоп1е = [ 
'+1е14$' => Фипс®1тот () { 
гефигп |[ 
‘'пемз" => [ //Добавляем диегу запрос пеш5 
'Фуре" => Турез: :пем$(), // Создаем новый тип данных 
'аг=2$" => | 
'14' => Турез::1пЁ(), // Добавляем аргумент, по которому мы можем получить новость 


с1а$$ ОцегутТуре ехепа$ ОБ]ес*Туре 
{ 


рчб11с ФипсЕ1оп __ соп5гисе() 


1, 


'гезо1\уе' => Фипс1оп ($гоо*, $агв5, $сопфехе, $1п®о) { 
гефигп М№ем$ : :деЁ($аг2$); // Добавляем метод деЁ для получения результата запроса 


} 
] 
1; 
} 
1; 
рагеп* : :__ соп5гис®($соп+12); 
| 
} 


р РНР Низза 
2022 


3. сгарНОГ: внедрение и советы 
(нлмк) 3.1. Базовая структура 


с1а$$ Турез ехфепа$ Туре 
{ 
рг1\уафе $%аЕ1с $диегу; 
рг1уаЕе $+аЕ1с $пем5; 
рг1\уафе $фаЕ1с $киритс; 


Регистра ция типа пе\/$ 


риб11с $фа%1с ФипсЕ1опт диегу() 


{ 
гефигп $е1+::$диегу ?: (5е1+::$диегу = пем ОцегуТуре()); 

} 
о РЕ о БИЯ РБ ба ВО ОБЕ ОБЬ В д ВИ а О а НЙ, Е До ОЖ БЕСТ БЫ В вЫ СБ од БЕ БН АВ | 
| риб11с $Фаф1с Рипс® Топ пем$() // Зарегистрировали новый тип | 
{4 | 
| гефигп $е14: :$пем5 ?: (5е1+::$пеиз = пем №ем5Туре()); //необходимо описать поля этого типа 1 
| } | 


3. сгарНОГ: внедрение и советы 


3.1. Базовая структура 


с1а5$ МеимзТуре ехепа$ ОБ)есеТуре 5 Описание возвращаемых 
полей для типа пем/$ 


рчб11с ФипсЕ1оп __ соп5гисе() 


| 
фсоп+1в = [ 
'+1е14$' => Рипс®тот () { 
гефигп [ //описали поля таблицы и указали их типы 
'1а' => | 
'Фуре' => Турез::1ит(), 
1, 
‘пате’ => [ 
'фуре’ => Турез: :5/71пд(), 
1, 
'Фехе' => [ 
'фуре’ => Турез: :5/71пд(), 
1, 
]; 
} 
]; 
рагеп* : :__ соп5гис®($соп+1=); 
} 
} 


р РНР Ноизза 


2022 


3. огарНОГ: внедрение и советы 
(нлмк) 3.1. Базовая структура 


патезрасе МЕМК\бгарпо\Арр\Туре; Описание получения 


а данных из БД для новости 
и$е МЕМК\бгарпо! \Арр\ОВ\Соппес ОВ; 


с1а$$ Мем$ 
{ 
ричб11с $фа1с РипсЕ1оп рее ($аг55) 


{ 
$ОВ = пем Соппес®рВ(); 


гефигп $ОВ->ачцегу ("ЗЕТЕСТ * 1гот пем$ ИНЕВЕ 14 = {Фаг8$['1а']}") [9]; 
} 


| 


3. сгарНОГ: внедрение и советы 


3.1. Базовая структура 


{"ачегу":"{пемз (14: 6130) {19, пате, +ех*}}"} 


СгарпО1: проверка работы 


Г: 
Ф 
(=) 
© 
Ф 
Теж /$ОМ ХМЕ НТМЕ = Роппа! Боду ЕпаЫе Боду еуашабоп Я 
Кезропзе ИННЫ 
200 ОК 
> 
› ВООУ ргену * 
[72 
= ВИ 
Е дата: х { 
Ф 
пем$: т |[ 
* { 
19: 6139, 


пате: “Бронза из Магнитогорска", 
+ех*: "‹р></р><41\у а11вп=\"]из{1Ру\"><а1\у а11вп=\"]и$1у\"><р>‹ 


} Фтор ФвВошют  @СоПарзе Ореп №2Вечиех Сору 4 Оомпюаа 


› 


3.1. Базовая структура 


ВОБУ 


{"ачегу" :"{пешз (14: 6130) {14, пате}}"} 


Тех /$ОМ ХМЕ НТМЕ | = Роппаё Боду | ЕпаЫе Боду еуашайоп 


ВОПУ 
ху Г 
| 
Дафа: * { 
пез: т | 
у! 
| 
19: 6136, 
пате: “Бронза из Магнитогорска" 
} 
3 
] 
} 


© Тор 


© Воцот 


© СоНарзе 


Теж = 


ргейу * 


3 Оомпюаа 


3. огарНОГ: внедрение и советы 


СгарпО!: проверка работы 


3. бгарНОГ: внедрение и советы 


3.2. Производительность: 


составной запрос (Опе $%ер) 


с1а5$ Оцегутуре ехфеп@$ ОБ)есфТуре Описываем запрос гиб пс 
{ 
риб11с ФипсЕ1оп __соп5гис*() 
{ 
$соп+1в = [ 
'+1е14$' => Фипс® тот () { 
гефигп [ 
а Вы Бо ое иены 
| "гибг1с' => [ //Добавили еще один запрос | 
| 'Фуре' => Турез::гиргтс(), // Создаем новый тип данных - рубрика | 
| 'аг=$' => | | 
| '14' => Турез::1пЕ(), // Добавили аргумент, по которому мы можем получить рубрику | 
1, | 
| 'гезо1\е' => ФипсЕ1оп ($гоо*, Фагв$, фсопфехЕ, $1пФо) { | 
| гебигп Кибг1с: :дет(Фагё5); // Добавляем метод деф для получения результата запроса | 
рае оо а оо о иной ола Они к. 
] 
1; 
} 
1; 
рагеп* : :__ соп5 Гис ($соп+15); 
} 


} 


3. бгарНОГ: внедрение и советы 


3.2. Производительность: 


составной запрос (Опе $%ер) 


с1а$$ Турез ехфепа$ Туре 
{ 
рг1\уафе $%аЕ1с $диегу; 
рг1\уаЕе $+аЕ1с $пем5; 
рг1\уафе $фаЕ1с $кгиритс; 


Регистрация типа гибйс 


риб11с $фаф1с ФипсЕ1опт аиегу() 


{ 
гефиги 5е1+: :$ацегу ?: (5е14+::$диегу = пем ОцегуТуре()); 
} 
рчб11с $Фаф1с ФипсЕТоп пем$() 
{ 
гефигп $е1+::$пем5 ?: (зе1+4::$пеи5 = пем М№ем$Туре()); 
} 


| риуб11с $фа1с ФипсЕ1от гибг1с() // Зарегистрировали новый тип 
Е 
| 
| 


| 
| 
гефигп $е14: :$киритс ?: (зе14::$киргтс = пем Вибг1сТуре()); // необходимо описать поля этого типа, 


3 2 Производительность: 3. огарНОГ: внедрение и советы 


составной запрос (Опе $%ер) 


с1а$$ Кибг1сТуре ехепа$ ОБ)есеТуре ^^ Описание возвращаемых 
У 


{ полей для типа гибмс 
рчб11с ФипсЕ1оп __ соп5гисе() 


{ 
фсоп+1в = [ 
'#1е14$' => Рипс®топт () { 
гефигп [ //описали поля таблицы и указали их типы 
"14" => | 
'фуре' => Турез::1ит(), 
1, 
‘пате’ => [ 
'фуре’ => Турез: :5/71пд(), 
], 
'соае' => [ 
'фуре’ => Турез: :5/71п9(), 
1, 
]; 
} 
]; 
рагеп* : :__ соп5гис®($соп+12); 
} 


| 


э 2 Производительность: 3. бгарНОГ: внедрение и советы 


составной запрос (Опе $%ер) 


патезрасе МЕМК\бгарпо\Арр\Туре; Описание получения 


а данных из БД для рубрик 
и$е МЕМК\бгарпо! \Арр\ОВ\Соппес ОВ; 


с1а$$ Кибг1с 
{ 
риб11с $фаЕ1с РипсЕ1оп рее ($аг55) 
{ 
$ОВ = пем Соппес*рВ(); 
гефигп $ОВ->ачцегу ("$ЕЪЕСТ * 1гот гибг1с$ МНЕВЕ 14 = {$аг2$ [ "1а']}") [9]; 


} 
} 


3. бгарНОГ: внедрение и советы 


3.2. Производительность: 


составной запрос (Опе $ер) 


с1а$$ МемзТуре ех&епа$ ОБ]ес%Туре 5 Описание возвращаемых 
{ У полей для типа пе\м$ 
ричб11с ФипсЕ1оп __соп5гис*() 
{ 
$соп+1в = [ 
'+1е14$' => Рипсё1топт () { 
гефигп [ 
"14" => [ 
'уре’' => Турез::1пЕ(), 
], 
‘пате’ => | 
'Фуре' => Турез: :$фг1п9(), 
], 
'ехе’ => | 
'Фуре’' => Турез: :$тг1пд9(), 


Г 'гиубите" => [ | 
'КФуре" => Турез: :Кибг1с(), //добавляем тип для возврата 14а рубрик 


рагеп* : :__ соп$кис ($соп+1е); 


э 2 П роизводительность: 3. огарНОГ: внедрение и советы 


составной запрос (Опе $%ер) 


> {"дчегу":"{пемз (14: 6130) {14, пате, Жехе, гибг1с}}"} 
[72 
Ф 
и=) 
© 
-- 
Теж /5ОМ ХМЕ НТМЕ = Ропта! Боду ЕпаЫе Боду еуамайоп @ 
Кезропзе 
200 ОК 
> 
› ВОБУ ргейу = 
Ф ь д 
ы { 
Е дафа: * { 
Ф 
пемз: х |[ 
* { 
14: 6130, 
пате: “Бронза из Магнитогорска", 
+ех*: "<р></р><41\ а11вп=\"]и$1Ру\"><41\у а11еп=\"] и 1Ру\"><р>‹ 
кибг1с: 18 
} 
] Фтор ФвВош№т ШЯСойарзе @Ореп №®2Ведиех ЯСору 4 Оомпюаа 
} 


(нлмк) р Производительность: 3. огарНОГ: внедрение и советы 
составной запрос (Опе $%ер) 


— г" и.н * И — з "3 У 
Е {"дчегу":"{пемз (14: 6130) {14, пате, Жехе, гибг1с}}"} Нам вернулся корректный ответ, но 
р чтобы получить рубрику новости, 
необходимо послать 2 запроса ($4ер-Бу- 
${ер): 
1.  пем/5 ^ 159 тз$ 
Теж /ЗОМ ХМЕ НТМЕ = Ропта{ Боду ЕпаЫе Боду еуамабоп ®] 
Кезропзе 
200 ОК 
> 
› ВОБУ ргейу = 
Ех 
Е дафа: > { 
— пемз: т | 
и { 
14: 6130, 
пате: “Бронза из Магнитогорска", 
+ех*: "<р></р><41\у а11вп=\"]и$1Ру\"><41\у а11еп=\"] из 1Ру\"><р>‹ 
гибг1с: 18 
} 
] Фтор ФвВош№т ШСойарзе @Ореп №®2Вечиех ЯСору 4 Оомпюаа 
} 


(нлмк) р Производительность: 3. ОгарНОГ: внедрение и советы 
составной запрос (Опе $%ер) 


› ВОО Тех * Нам вернулся корректный ответ, но 


{"адчегу" :"{гибг1с (14а: 18) {149, пате, со4е}}"} 


й чтобы получить рубрику новости, 
з необходимо послать 2 запроса ($4ер-Бу- 
${ер): 
1. пем/ ^ 159 т5 
2.  габмс ^121 т5 
Теж /$ОМ ХМЕ НТМЕ = Ропта{ Боду ЕпаЫе Боду еуамайоп м 
Итого: ^280 т$ 
Кезропзе 
› 200 ОК 
ы вору ргейу = 
Ф И 
‚= \ 
Е дафа: > | 


14: 18, 
пате: “НЛМК РКО", 


соде: “п|иКрго" 


— 


] ©Тор ФВофот Е СоЙарзе Ореп № 2Кедиехм @Сору 4, )омпоаа 


= 


(нлмк) р Производительность: 3. ОгарНОГ: внедрение и советы 
составной запрос (Опе $%ер) 


›  ВОБУ Тех! * Нам вернулся корректный ответ, но 


{"адчегу" :"{гибг1с (14а: 18) {149, пате, со4е}}"} 


чтобы получить рубрику новости, 


| необходимо послать 2 запроса ($4ер-Бу- 
${ер): 
1. пе\м$ ^ 159 т$ 
2.  габмс ^121 т5 
Теж /$ОМ ХМЕ НТМЕ = Гоппа! Боду ЕпаЫе Боду еуамабоп @) 
Итого: ^280 5$ 
Кезропзе р АНиВЬ 
‚ ТЕЖ 
Реализуем составной запрос, чтобы 
›  ВООУ ргену * мы могли получить эти же данные 
при одном запросе (Опе-$%ер). 
| — 
р | 
Е дафа: > | 


кибг1с: х [ 
и 
14: 18, 
пате: “НЛМК РКО", 


соде: “п|иКрго" 


— 


] ©Тор ФВоНот Е СоЙарзе Ореп №2Ведием Сору 4 Помпюад 


= 


3. бгарНОГ: внедрение и советы 


3.2. Производительность: 


составной запрос (Опе $%ер) 


с1а$$ МемзсТуре ехфепа$ ОБ)]ес®Туре 55 Реализуем составной запрос 
“ 


{ 


ричб11с РипсЕ1оптп __соп5гис*() 
{ 
фсоп1е = [ 
'Ё1е14$' => ФипсЕ1от () { 
гефигп |[ 
'14' => ['%уре' => Турез::1иЁ()], 
'пате' => ["фуре" => Турез: :5Ё71пд()], 
'Жехе' => ['%уре' => Турез: :$Ё71пд9()], 
‘гибг1с' => [ //описали вложенный запрос на получение рубрики новости 
_ —'$уре“ =>_Турез : рибис (> анна 
//передаем 6 метод параметры для отбора рубрик по родительским вбозвращаемым полям 1 
'гезо1\уе' => Фипс1оп ($гоо*, $агв5, $сопфехе, $1п Ко) { | 


| 
| 
| гебигпт Вибг1с: :деЕ(['19' => $гоо{ [ " гибг1с']]); 
| 


1; 
рагеп* : :__ соп$гис® ($соп+15); 


| 


(нлмк) р Производительность: 3. бгарНОГ: внедрение и советы 
составной запрос (Опе $%ер) 


{"ачегу" :"{пемз (14а: 6130) {1а, пате, +ех®, гибг1с{1а, пате, со4е}}}"} Нам вернулся корректный ответ по 
Е новости и рубрике за один шаг (Опе 
2 Теж /$ОМ ХМЕ НТМЕ = Роппа! Боду ЕпаЫе Боду еуамайоп @ ЬМе $ер) 
Кезропзе е расе - Нарзед Те: 161 Итого: ^161 т$ 
200 ОК 
› ВООУ ргецу * 
ео 
Е дата: х* { 
> Г = 
пеш: т |[ 
в { 
14: 61360, 


пате: “Бронза из Магнитогорска", 


+ех*: "‹р></р><@1\у а11еп=\"]из1Ру\"><1\у а11еп=\"]из1Ру\"><р>‹ 
кибг1с: х { 

14: 18, 

пате: “НЛМК РКО", 


соде: “п]иКрго" 


] ©ФТор ФвВошот — @ СоПарзе Ореп № 2Кециех @Сору 4, Оомптоаа 


3. сгарНОГ: внедрение и советы 


3.2. Производительность: 


составной запрос (Опе $%ер) 


{"диегу":"{пемз (14: 6130) {19, пате, +ех+, гибг1с{19, пате, со4е}}}"} Нам вернулся корректный ответ по 
Е новости и рубрике за один шаг (Опе 
|- Теж /$ОМ ХМЕ НТМЕ = Ропта! Боду ЕпаЫе Боду еуашавоп @) $ер) 
Кезропзе е равсе4 - Барзед Тите: 161 Итого: ^161 т$ 


200 ОК 


› ВОО ргецу * 
у | $4ер Бу Опе $1ер 
Г = | $ер 
1 Ё Чата: у { Производительность “280 т5 “161 тб 
пемз: я | 
* { — 57,5% 


19: 6136, 
пате: “Бронза из Магнитогорска", 
+ех*: "‹р></р><@1\у а11еп=\"]из1ФРу\"><1\у а11еп=\"]из1у\"><р>‹ 
кибг1с: х { 
19: 18, 
пате: “НЛМК РКО", 


соде: "п1]иКрго" 


] ©Тор ФвВошюот  @ СоЙарзе Ореп №2Кециех @Сору 4, Оомтоаа 


3.3. Безопасность: Разграничение 
прав доступа (М/ЙКе 1151) = 
\ 


3. сгарНОГ: внедрение и советы 
3.3. Безопасность: Разграничение прав доступа (\М/НКе 1151) 


с1а5$$ ОцегуТуре ехфепа$ ОБ)ес*Туре Добавление проверки в корневой тип данных 


риб11с Фипс&1оп __соп$гис*() 
{ 
фагСоп+1= = [ //Вынесли наши Обиегу запросы 6 массив 
‘пем$' => | 
фуре' => Турез: : [1501 (Турез: :пем5()), 
'аг2$' => | 
'14' => Турез: :1пЕ(), 
], 
'ге$о1\е' => ФфипсЕ1оп ($гоо*, $агв$, $соп%ехе, $1пРо) { 
гефигп Мем5: : де ($аг25); 
} 

], 

"гибг1с' => [|], 
р а ыы 
| $соп+1в = [ 
| 'Ё1е14$' => ФипсЕ1от () изе (ФагСоп+1е) { 
| //проверка доступов к методам и его полям 
| гефигп Реги1$$1оп: : ргосе55Соп}149Ете(а$5 ($агСоп{12); 
| 
| 


3. огарНОГ: внедрение и советы 
(нлмк) 3.3. Безопасность: Разграничение прав доступа (М/НКе 1151) 


патезрасе бгарпо!\Арр\АчЕИ; //файл Арр\АитР\Регтт55топ.рИр Структура конфигурационных данных 
ие бгарпо! \5егуег\Кедие Еггог; 


с1а$$ Регт1$$1о0п 


{ 
рг1\уаЕе $+аЕ1с ЗепуСоп{Та = [ 
[ 
"ГОСТМ" => "ТЕЗТ", 
"РАЗЗИОКО" => "123456", 
"ИНТТЕЕТЬТ" => | 
"пем5" => ["14", "пате", "фехе"] //разрешенный метод и Возвращаемые поля для пользователя 
] 
1, 
[ 
"ЕОСТМ" => "КУВАТС_У$ЕВ", 
"РАЗЗМОКО" => "654321", 
"ИНТТЕЕТЬТ" => | 
"гибг1с" => ["1а"] . . 
*Рекомендуется выносить данные параметры за пределы корневои директории саита 
] (РОСУМЕМТ_ВООТ) 
] 
} 


р РНР НКизза 
2022 


3. бгарНОГ: внедрение и советы 


3.3. Безопасность: Разграничение прав доступа (М/НКе 1151) 


с1а$$ Регт1$$1о0п 


Метод проверки данных 


ричб11с $фаЕ1с ФипсЕ1оп ргосе$$СопЕ12Е1е14$ ($11е1а$) 


Фогеасй ($+1е145 аз $со4е => $фагЕ1е1а) { 


$+1е1а$ [$соае] [ 'гезо1\е'] = Фипс1оп ($гооф, $аге$, $сопехе, $1пРо) чзе ($со4е, $агЕ1е1а) { 


$гези1{ = $агЕ1е1а[ 'гезо1уе' ] ($гоо*, $агв5, $соп%ех®, $1п+о); 


//проверка доступа 
5е1+: : срескАссе55 ($соде, аггау_Кеу$(сиггепЕ ($гези1*))); 


//6 случае успеха возвращаем результат 
гефигп $гези1*{; 


}; 
} 


гефигп $+1е14а$; 


Р РНР НКозза 


3. сгарНОГ: внедрение и советы 
3.3. Безопасность: Разграничение прав доступа (М/НКе 1151) 


с1а°х Реги1$$10п Метод проверки доступа к переданному типу запроса и его аргументам. 
{ 

/** Метод проверки доступа к переданному типу запроса и его аргументам */ 

рг1уафе $%а%1с Фипс®1оп сПпескКАссе$$ ($%г14пв $теЕродМате, аггау $аг25) 


{ 
1+ (!етрфу($_ЗЕВУЕК[  "РНР_АЧТН_У$ЕВ'])) { 

‚ //Пробверим, разрешен ли запрос для пользователя 
1+ ($ $ЕВ\МЕВ[ 'РНР_АУТН_9$ЕВ'] == $агИзег[ 'ЕОбТ№'] && 
| $ $ЕВУ\ЕК [ 'РНР_АУТН_РМ"] == $агИ5ег[ 'РАЗЗИОВО' ]) { 
| 1+ (!1и_аггау($тежпо9Мате, аггау_Кеу$ ($ФагУ5ег[ 'ИНТТЕЕТЗТ']))) { 
| {Игом пем Ведие$+Еггог ($теЕпоЧМате . ' 1$ ФогЬ1а4еп Рог изег '. $аг0зег['1061№'], 401); 
| 
—_` //Проверим, разрешены ‘ли Возвращаемые поля запроса для пользователя. о 

фогеасН ($аг25 а$ $+11е1а) { 

1+ (Ф$аг0зег['ИНТТЕЕТФТ ' ] [$теЕпо4Мате] && 
!1п_аггау($+1е14, $агИзег|['ИНТТЕЕТ$Т ' ] [$теЕпо9Мате])) { 


{Игом пем ВКедие$Еггог ($+11е1а . ' 1$ Фогб1адеп Фог изег ' . $агзег['1обтТм'], 401); 
} 
} 
} 
} 
РНР Кизза 


3. огарНОГ: внедрение и советы 
(нлмк) 3.3. Безопасность: Разграничение прав доступа (М/НКе 1151) 


с1а°х Реги1$$1оп Метод проверки доступа к переданному типу запроса и его аргументам. 


| 


/** Метод проверки доступа к переданному типу запроса и его аргументам */ 
рг1уафе $%а%1с ФипсЕ1оп сПпескКАссе$$ ($%г14пв $теЕродМате, аггау $аг25) 
{ 
1+ (!етр%у($_$ЕКУЕВ[ "РНР_АЧТН_9$ЕВ'])) { 
ФогеасН ($е1+: :$епуСоп}14 аз ФагУзег) { 
//Проверим, разрешен ли запрос для пользователя 
1+ ($ 5ЕВУЕВ[  'РНР_АЧТН_У$ЕВ'] == ФагИзег[ '10бТ№'] && 
$ ЗЕВУЕК[  "РНР_АУТН_РИ'] == $агИзег[ 'РАЗ$ЗМОКВО']) { 
1+ (!1п_ аггау($теЕпо9Мате, аггау_Кеу$($агУзег['ИНТТЕЕТ$Т']))) { 
{Игом пем Ведче$Еггог ($те{поЧ9Мате . ' 1$ ФогЬ1Адеп Фог изег '. $агИзег['106тТМ№'], 401); 


р. //Проверим, разрешены ли вбозвращаемые поля запроса для пользователя 
| ФогеасИ (Фагё5$ аз $+1е1а) { 

| 1+ ($аг0зег['ИНТТЕЕТФТ ' ] [$теЕпо4Мате] && 

| !1п_аггау ($+1е1а, $агУ5ег["ИНТТЕЕТ$Т ' ] [$тефподМате])) { 

| 

| 


{Игом пем ВКедие$Еггог ($11е1а . ' 1$ Фогб1та4еп Фог изег '. $аг0зег['Еобтм'], 401); 


РНР Низза 
2022 


3. бгарНОГ: внедрение и советы 


3.3. Безопасность: Разграничение прав доступа (М/НКе 1151) 


{"ачегу":"{пемз (14: 6130) {19, пате, +ехе, гибг1с{19, пате, со4е}}}"} 


| 
ФФ 
(=) 
(3 
Ф 
= Тех /$ОМ ХМЕ НТМЕ = Гоппа! Боду ЕпаЫе Боду еуашавоп @ 
Кезропзе 
› ВОБУ ргецу * 
Ф { 
Е: ыы 
к) 
< еггог$: я | 
› 2 


у! 


| 


мез5аёе: “Мефпо пемз 1$ Фогб1А4еп Фог изег ТЕЗТ", 
сафевогу: “вгарпа1", 


]Тоса*10п$: т | 


я { 
11те: 1, 
со]1итп: 2 
ет 
) 
1, 
ран: (>) [ 
"пемб и" 
л © Тор © Вовот © СоНарзе Ореп № 2Кедие=! @# Сору 3 Оомпюаа 
г 


у$5ег$ 


3.4. Гибкость: 
Реализация сложных фильтров с 
логикой ОВ/АМО — 


(нлмк) 3.4. Гибкость: Реализация сложных фильтров с логикой ры. 
ОВ/АМО 


Необходимо: 


7’ ( создать новый тип данных (Мхедтри Туре). Который будет прототипом для 
== автоматической генерации классов со сложной логикой и добавлением в Оицегу- 
запросов налету. 


зарегистрировать новый тип данных 


^^ добавить логику обработки в тип Оуегу запросов 


(нлмк) 3.4. Гибкость: Реализация сложных фильтров с логикой ты 
ОВ/АМО 


Класс должен автоматически генерировать/расширять все типы данных для реализации сложных 
фильтров стипами “ОВ”/”АМО” в режиме реалтайма, НО 


(нлмк) 3.4. Гибкость: Реализация сложных фильтров с логикой ее 
ОВ/АМО 


Класс должен автоматически генерировать/расширять все типы данных для реализации сложных 
фильтров стипами “ОВ”/”АМО” в режиме реалтайма, НО 


Библиотека не работает с одноименными классами данных и выдает ошибку. 
«5сНета ппи${ сомат ипаче патеа туре$ Би* сопатз$ тире {урез патед "\бгарпО\Арр\Туре\три \М!хедтриТуре\" 
(сее ИИр://\меБопух.=ИПиб.1о/вгарпа!-рИр/куре-зужет/#Журе-ге21$гу).» 


(нлмк) 3.4. Гибкость: Реализация сложных фильтров с логикой ее 
ОВ/АМО 


Класс должен автоматически генерировать/расширять все типы данных для реализации сложных 
фильтров стипами “ОК”/”АМО” в режиме реалтайма, НО 


Библиотека не работает с одноименными классами данных и выдает ошибку. 
«5спета ппи${ сомат ипаче патеа туре$ Би* сопатз$ тире {урез патеа "\бгарпО\Арр\Туре\три \М!хедтриТуре\" 
(сее ИИр://\меБопух.=ИПиб.1о/вгарпа!-рИр/куре-зужет/#Журе-ге21$гу).» 


Для обхода ограничения необходимо добавлять «соль» при автогенерации новых типов 
данных 


(нлмк) 3.4. Гибкость: Реализация сложных фильтров с логикой ее 
ОВ/АМО 


с1а$$ М1хейТпри Туре ехеп@а$ Тпри*ОБ)ес*Туре Ноб Ао ВВ 
| риб11с ФипсЕ1Топ __соп$Егис® (аггау $агЕхкепаедЕ1е1а$ = []) ^ 
р . $зНазНбепегаеа Е та5 (1трроде (" р ", `ФагЕХепде9Е1е14$));//создаем хеш аргументов и | 
ООО | 


//абтоформирование схемы типов, генерация уникального имени для нового типа, например, 
//бгарпоЕ \Арр\Туре\Тприт \МтхеаТпритТуред5арабесЬь065сфа7Ь660а6Ь6а59а54с} 
'пате’' => $е14: :с1аз$ . $$На$Ибепега*еа, 


//опишем абтоформирование полей для диегу запросов 
'Ё1е14$' => Фипс®1оп () изе ($агЕхеепадеаЕ1е1а$, $$НазПбепегаееа) { 


} 
1; 
рагеп*: :__ соп$гисЕ($соп+ 15); 
} 
} 


(нлмк) 3.4. Гибкость: Реализация сложных фильтров с логикой ее 
ОВ/АМО 


с1а$$ М1хейТпри Туре ехфепа$ Тпри*ОБ)ес*Туре Ном Ао ВВ 
{ С 

рчб11с РипсЕоп __соп5гис* (аггау $агЕх+епаедЕ1е1а$ = []) 

{ 


$НазПбепегафед = та5(1тр(оае(',', ФагЕхепаедЕ1е1а$));//создаем хеш аргументов 


фсоп18 = |[ 

//абтоформирование схемы типов, генерация уникального имени для нового типа, например, 
| : 
| //бгарпоЕ \Арр\Туре\Тприт \МтхеаТпритТуред5арабесЬь065сфа7Ь660а6Ь6а59а54с} 
| 


| 
| 
'пате’' => $е14: :с1а$$ . $$На$Ибепега*еа, | 


ны оо о а ааа мы аа ра а ыы мар а зар вы обо ар рая Зап: В а ый ы 
//опишем абтоформирование полей для диегу запросов 
'Ё1е14$' => Фипс®1оп () изе ($агЕхеепадеаЕ1е1а$, $$НазПбепегаееа) { 
} 
1; 
рагепе: :__ соп5 Гис ($соп+1=); 
} 
} 


(нлмк) 3.4. Гибкость: Реализация сложных фильтров с логикой ее 
ОВ/АМО 


с1а$$ М1хейТпри Туре ехфепа$ Тпри*ОБ)ес*Туре Ном АВВ 
{ С 

рчб11с РипсЕоп __ соп5гис* (аггау $агЕх+епаедЕ1е1а$ = []) 

{ 


$эНазПбепегаЕед = та5(1тр(оае(',', ФагЕхепаедЕ1е1а$));//создаем хеш аргументов 


$соп+1в = [ 

//абтоформирование схемы типов, генерация уникального имени для нового типа, например, 
//бгарпоЕ \Арр\Туре\Тприт \МтхеаТпритТуред5арабесЬ065сфа7Ь660а6Ь6а59а54с} 

'пате’' => $е14: :с1а$$ . $$На$Ибепега*еа, 


| //опишем абтоформирование полей для диегу запросов 
| 'Ё1е14$' => Фипс®1оп () изе ($агЕхеепаеаЕ1е1а$, $$НазПбепегаееа) { 


рагеп* : :__соп$ кис ($соп+15); 


(нлмк) 3.4. Гибкость: Реализация сложных фильтров с логикой ры. 
ОВ/АМО 


Нод [ данных Мхедтри{Туре 


'Ё1е14$' => Фипс%1оп () чзе ($агЕхепаедЕ1е14$, $5НазИбепега*еа) { 
ии. ..,.оэ. | 
'Фуре’' => Турез: : [1501 ( 
пем ТприОб]есеТуре( 
[ 
'пате’' => $е14: :с1аз$ . 'О0ОК'’. $$НазПбепега*еа, 
'Ё1е14$' => Фипс%1оп () чзе ($агЕхепаедЕ1е1а$) {гефигп $агЕх+епаедЕ1е145 ; } 


г 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 


3. огарНОГ: внедрение и советы 


(нлмк) 3.4. Гибкость: Реализация сложных фильтров с логикой 
ОК/АМО 
Нод [ данных Мхедтри{Туре 
'+1е14$' => Фипс®1оптп () чзе ($агЕхепаеаЕ1е1а$, $НазНбепега*еа) { 
гефигп [//абтоформирование полей для Оиегу запросов 


‘ОВ’ => [ 
'Фуре’' => Турез: : [1501 ( 

пем ТприфОб]есеТуре( 
. $5НазИбепегажеа, 


[ 
‘пате’ => $е14::с1а$5$ . 'ОВ' 
'Ё1е14$' => Фипс%1оп () чзе ($агЕхепаедЕ1е1а$) {гефигп $агЕх+епаеаЕ1е1а5; } 


а 


(нлмк) 3.4. Гибкость: Реализация сложных фильтров с логикой ры 
ОВ/АМО 


с1аз$ М1хедтпри{Туре ехеепа$ Тпри*ОБ3есеТуре Наб" А 
риБ11с ФипсЕТоп __ соп5гисЕ(аггау $агЕхепаеаЕ1е14$ = []) 
{ 
$5НазИбепега+еЯ = та5(1тр(о4е(',', ФфагЕхепаеаЕ1е1а$));//создаем хеш аргументов 
$соп+18 = [ 


‘пате' => $е1+::с1аз$ . $$5НазИбепегафеа, //абтоформирование схемы типов, генерация 
уникального имени для нового типа, например, 
@гарпоЕ \Арр\Туре\Тприт \МтхеаТпри*Туред5аравесЬ 065 сфа7Ь669а6Ь6а59а54с} 
'Ё1е14$' => Фипс®1оп () чзе (фагЕхжепдеаЕ1е14$, $$НазПбепега*еа) { 
геигп [//абтоформирование полей для Обиегу запросов 
‘ОВ’ => [ 
'Фуре’ => Турез: : [1501 ( 
пем ТприЕОБ]ес*Туре( 
[ 
'пате’' => $е14: :с1а5$ . 'ОВ'’ . $5$На$Ибепега*ед, 
'Ё+1е14$' => ФипсЕ1оп () изе (ФфагЕхжепаедЕ1е1а$) {гефигп $агЕх+епдедЕ1е145; } 
] 
) 
) 
1, 
'АМО" => [/*аналогично ‘ОВ? за исключением поля пате - Вместо ‘ОЕ? указать ‘АМО?*/] 
1; 
} 
1; 


|= ВЫ : _ СОП$ГИСЕ($соп+15); 


с В ВОГ: 
(нлмк) 3.4. Гибкость: Реализация сложных фильтров с логикой а 
ОВ/АМО 


с1а$$ Туре ехепа$ Туре ® © регистрация нового типа данных 


| 


рг1\уафе $+а1с $диегу; 1 
рг1\уаЕе $+аЕ1с $ттхеаТпри®; 


риб11с $фаф1с Фипс&1от ачегу() 


{ 
} 


гефигп $е1+: :$диегу ?: (5е1+: :$диегу = пем ОчегуТуре()); 


/**Смешанный тип данных для диегу запроса*/ 
рчб11с $фаЕ1с РипсЕ1оп п1хедТпри*(аггау ФагЕхепадедЕ1е1а$ = []) 
{ 
$эАгРитеп*$ = та5(1тр(о4е(",', фагЕхЕепаеаЕ1е1а$)); 
гефигп $е1+: : $ттхедТириЕ [$5Агвитеп*$] ?: 5е1: : $ттхедТпри  [$зАгвитеп*$] = пем 
М1хедТприЕТуре (ФагЕхепаеаЕ1е145); 
} 
} 


(нлмк) 3.4. Гибкость: Реализация сложных фильтров с логикой ть 
ОВ/АМО 


с1а$$ ОшегуТуре ех&епа$ ОБес*Туре = ® Внедрение логики обработки 
“ 
рчб11с ФипсЕ1оп __ соп5гисе() 
{ 
фагСоп+1в = [//Вынесли наши Оиегу запросы 6 массив 
‘пем$" => |[ 
'Фуре’ => Турез: : [15 0} (Турез: : пем5()), 
'аг2?$' => ['14' => Турез::1иЕ()], 
'ге5о1\уе' => Фипс1оп ($гооф, $агв$, $сопфех®, $1п+о) {гефигп № м5: :деё(Фагв5);} 
], 
Е = = 5 =5ы 50ы 0ы 0ы =0ы =0ы 0ы =0ы вы =0ы = Н =ыН => Н = = = Е = = = === .= ===. .-= == =. = [== = [== = == = = =... = ь | 


| $фсоп1е = [//формируем фильтры со сложной логикой для каждого типа данных | 
| 'Ё1е14$' => ФипсЕ1оп () че (ФагСоп+1#) { | 
Фогеасй ($агСопР1= аз $$СодеСоп+1в => $агРагат$) { | 
| фагСоп+ 18 [$5СодеСоп+18][ 'агв$' ] [ "+11ег'] = | 
г Турез: : [1501 (Турез : : ттхедТприЕ (ФагСоп+18 [$$СодеСоп+18] ['аг2$'])); | 
| | 

| 


гефигп ФфагСоп+18; 


рагеп* : :__ соп$гис ($соп+15); 


3. бгарНОГ: внедрение и советы 


3.4. Гибкость: Реализация сложных фильтров с логикой 


ОК/АМО 


Ручная генерация - === Автоматическая генерация == 


с1аз5$ ОпегуТуре ехеепаз > с1аз5 ОпекуТуре ехеепа5 
рур11с ЕапсЕ1оп \ раю11с ЕапсЕ1оп 


загСопЕ1а \ б$агСопЕ1‹ //Вынесли наши Оцегу запросы в массив 1 


'реиз' 'пемз' 
'суре' ЕО1 и , 'суре' , 
'ага5' | ‘атав! 
та" 1 : а 1 р 
г вин ‘БЫ Скныи ваши” Бык  выши — Бшыы ) пиши пиши  пши паши  пвшы  пвши  пшы пи пы пы пы паши пы паши ваш ваша Ри ' . р 
"ЕТ Еех" //повторяющийся аргумент "Е116ег" с логикой ОВ\АМО для типа пемз @& ‘гезо1хе' ЕапсЕ1оп р г95, опфехЕ, $1пЕо 
| 'раме' '1091сЕ11ЕегМемз', | хеЕигп > / 
'Е1е1аз"' ЕапсЕ1оп 

| тебцей | , 

"ОВ" Й 7 

'Еуре' 11 1 | 
| пе $сопЕ1 9 
| 'Е1е1аз' ЕапсЕ1оп 5е 2 $ 
| 'папе' зе1Ё: : с1азз 'ОВ' 'ремз', с. ты ИИ. рмируем фильтры ‹ Я а Данных иы а 
'Е1е1а$' ЕапсЕ1оп | Еогеас загСопЕ1а 5 оаеСс ь 
| хебагп //повторяющиеся аргументы фильтра для типа пеиз | багСопЁ1а ] пЕ19 ага5 "ЕЛ Еее" | 
фа“ 1 м | СОР :. 'агаз' Я 
| 'соае' ы Е а са аа м в а а сы в к ок с в в сы: И 
; | гебагп ЗакСопЁ1с; 
| 
; 

| | 
| ; | рагепЕ 151 $сопЕ1а); 

'АМО' | 
| Дана иь ль бьет Пава ааа ив 


Би’ Бы: вы" ааа. ый: ий ше шир ыы" ыы ыы Бы’ аш: ый аш’ Бы Бы баш авы ии" Бы Брак’ Бла ай 


ЕапсЕ1оп ($гоое, багаз, $сорбехЕе, $1пЕо 


, 
; 
$сопЕ1а 
'Е1е145' ЕапсЕ1оп изе ($агСопЁ1а 
гебигп $агСопЕ19; 


3.4. Гибкость: Реализация сложных фильтров с логикой ры. 


ОК/АМО 


› ВООУ Тех * 
с {"диегу" :"{пем$ (+1]4ег: {ОВ: [414: 6130},{14: 6137}]}) {14, пате, +ех*, гибг1с{19, пате, со4е}}}"} 
Ф 
Ф 
>) 
[&) 
Ф 
И Тех /ЗОМ ХМЕ НТМЕ | = Роппа{ Боду ЕпаЫе Боду еуашабоп @ 
Кезропзе 
200 ОК 
› ВООУ ргейу я 
› 
ШУ 
Е гы 
- дафа: * { 
пез: т | 
› 
› 
› 


бпез питз  @ сору 


©Тор ФВошот — И СоЙарзе Ореп № 2Веаиех @Сору 4. ПОомпоаа 


4. Выводы 


У Мы описали >20 «простых» типов данных 
У Всреднем 1 «комплексный» тип данных состоит из 3-х подтипов 
Итого: нам удалось реализовать >1 000 комбинаций/сочетаний. 
СК __ т! 
п бпюЮк!’ 


где! = множество/количество объектов, 


К — количество сочетаний объекта 


СЗа = РНЕ НИИ 1140 
20 (20-3)! *3! 


4. Выводы 


У Определите назначение системы в разрезе 
поставщик/потребитель 


У Реализовывайте принцип Опе $%ер-запросов 


У Заложите систему разграничения доступа к 
объектам и их сущностям для каждого потребителя 


У Настройте систему логирования с четкой 
фиксацией потребителя, который запрашивает 
информацию 


У Сделать фильтр со сложной логикой для большей 
гибкости запросов 


д о 


р И Клад 


Сергей Тарасов, к.т.н’, 


и . на 

руководитель команд разработки, о и, ы 

Група НЛМК 7 ОВ, Е 
Ета: 15егве!2012 @Етаи, сот ты р Ви 


рт еее 


Презентация Би. нмЗмькава 
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